﻿//==================================================================
// Copyright (C) 2011 深圳市中旭企业管理股份有限公司
// 文件名: V_TrQuestionnaire.cs
// 作 者：代码自动生成
// 日 期：2011-12-5 11:06:01
// 描 述：
// 版 本：1.00
// 修改历史纪录
// 版 本  修改时间      修改人            修改内容
// 1.00             
//==================================================================
using System;
using System.Collections.Generic;
using System.Linq;
using System.ComponentModel;
using System.Text;
using Csla;
using lite;
using Csla.Validation;
using Csla.Data;
using System.Data.SqlClient;
using ZX.DAL;
using OpenExpressApp.ORM;
using ZX.EHR.Library;
using System.Web;
using ZX.Common;
using System.Reflection;

namespace ZX.TR.Library
{
    /// <summary>
    /// 
    /// </summary>
    [Serializable]
    [Table(Name = "V_TrQuestionnaire")]
    [ZX.DBModule.Table("V_TrQuestionnaire", "TrQuestionnaireID")]
    public class V_TrQuestionnaire : ZX.DBModule.BaseEntity
    {

        #region Business Methods 业务方法

        /// <summary>
        /// ID
        /// </summary>
        private static PropertyInfo<Guid> TrQuestionnaireIDProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<Guid>("TrQuestionnaireID"));
        [DataObjectField(true, true)]
        [Column, PK]
        public Guid TrQuestionnaireID
        {
            get { return GetProperty(TrQuestionnaireIDProperty); }
            set { SetProperty(TrQuestionnaireIDProperty, value); }
        }

        /// <summary>
        /// 问卷类型(角度)
        /// </summary>
        private static PropertyInfo<Guid> QStyleIDProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<Guid>("QStyleID"));
        [Column]
        public Guid QStyleID
        {
            get { return GetProperty(QStyleIDProperty); }
            set { SetProperty(QStyleIDProperty, value); }
        }
        /// <summary>
        /// 问卷类型(角度)
        /// </summary>
        [Column]
        public string QStyleName
        {
            get;
            set;
        }
        /// <summary>
        /// 发起部门
        /// </summary>
        private static PropertyInfo<Guid> DeptIDProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<Guid>("DeptID"));
        [Column]
        public Guid DeptID
        {
            get { return GetProperty(DeptIDProperty); }
            set { SetProperty(DeptIDProperty, value); }
        }
        /// <summary>
        /// 问卷名称
        /// </summary>
        private static PropertyInfo<string> QuestionnaireNameProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("QuestionnaireName"));
        [Column]
        public string QuestionnaireName
        {
            get { return GetProperty(QuestionnaireNameProperty); }
            set { SetProperty(QuestionnaireNameProperty, value); }
        }
        /// <summary>
        /// 部门名称
        /// </summary>
        private static PropertyInfo<string> DeptNameProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("DeptName"));
        [Column]
        public string DeptName
        {
            get { return GetProperty(DeptNameProperty); }
            set { SetProperty(DeptNameProperty, value); }
        }
        /// <summary>
        /// 问卷目的
        /// </summary>
        private static PropertyInfo<string> QAimProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("QAim"));
        [Column]
        public string QAim
        {
            get { return GetProperty(QAimProperty); }
            set { SetProperty(QAimProperty, value); }
        }
        /// <summary>
        /// 题目总数
        /// </summary>
        private static PropertyInfo<int> SubjectSumProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<int>("SubjectSum"));
        [Column]
        public int SubjectSum
        {
            get { return GetProperty(SubjectSumProperty); }
            set { SetProperty(SubjectSumProperty, value); }
        }
        /// <summary>
        /// 问卷总分数
        /// </summary>
        private static PropertyInfo<decimal> PointSumProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<decimal>("PointSum"));
        [Column]
        public decimal PointSum
        {
            get { return GetProperty(PointSumProperty); }
            set { SetProperty(PointSumProperty, value); }
        }
        /// <summary>
        /// 问卷开始时间
        /// </summary>
        private static PropertyInfo<DateTime> QStartTimeProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<DateTime>("QStartTime"));
        [Column]
        public DateTime QStartTime
        {
            get { return GetProperty(QStartTimeProperty); }
            set { SetProperty(QStartTimeProperty, value); }
        }
        /// <summary>
        /// 问卷结束时间
        /// </summary>
        private static PropertyInfo<DateTime> QEndTimeProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<DateTime>("QEndTime"));
        [Column]
        public DateTime QEndTime
        {
            get { return GetProperty(QEndTimeProperty); }
            set { SetProperty(QEndTimeProperty, value); }
        }
        /// <summary>
        /// 问卷限制时长(分钟)
        /// </summary>
        private static PropertyInfo<decimal> QTimeLengthProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<decimal>("QTimeLength"));
        [Column]
        public decimal QTimeLength
        {
            get { return GetProperty(QTimeLengthProperty); }
            set { SetProperty(QTimeLengthProperty, value); }
        }
        /// <summary>
        /// 问卷须知
        /// </summary>
        private static PropertyInfo<string> QNoticeProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("QNotice"));
        [Column]
        public string QNotice
        {
            get { return GetProperty(QNoticeProperty); }
            set { SetProperty(QNoticeProperty, value); }
        }
        /// <summary>
        /// 问卷来源
        /// </summary>
        private static PropertyInfo<string> QSourceProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("QSource"));
        [Column]
        public string QSource
        {
            get { return GetProperty(QSourceProperty); }
            set { SetProperty(QSourceProperty, value); }
        }
        /// <summary>
        /// 是否允许跳过题目
        /// </summary>
        private static PropertyInfo<string> IsJumpOverProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("IsJumpOver"));
        [Column]
        public string IsJumpOver
        {
            get { return GetProperty(IsJumpOverProperty); }
            set { SetProperty(IsJumpOverProperty, value); }
        }
        /// <summary>
        /// 问卷总结
        /// </summary>
        private static PropertyInfo<string> QSumupProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("QSumup"));
        [Column]
        public string QSumup
        {
            get { return GetProperty(QSumupProperty); }
            set { SetProperty(QSumupProperty, value); }
        }
        /// <summary>
        /// 是否可用
        /// </summary>
        private static PropertyInfo<string> IsUsedProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("IsUsed"));
        [Column]
        public string IsUsed
        {
            get { return GetProperty(IsUsedProperty); }
            set { SetProperty(IsUsedProperty, value); }
        }
        /// <summary>
        /// 说明
        /// </summary>
        private static PropertyInfo<string> ExplainProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<string>("Explain"));
        [Column]
        public string Explain
        {
            get { return GetProperty(ExplainProperty); }
            set { SetProperty(ExplainProperty, value); }
        }
        /// <summary>
        /// 操作员编号
        /// </summary>
        private static PropertyInfo<Guid> AddUserProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<Guid>("AddUser"));
        [Column]
        public Guid AddUser
        {
            get { return GetProperty(AddUserProperty); }
            set { SetProperty(AddUserProperty, value); }
        }

        [Column]
        public string AddUserName
        {
            get;
            set;
        }	

        /// <summary>
        /// 新增时间
        /// </summary>
        private static PropertyInfo<DateTime> AddTimeProperty = RegisterProperty(typeof(V_TrQuestionnaire), new PropertyInfo<DateTime>("AddTime"));
        [Column]
        public DateTime AddTime
        {
            get { return GetProperty(AddTimeProperty); }
            set { SetProperty(AddTimeProperty, value); }
        }

        #endregion

        #region Validation Rules 验证规则
        //将验证规则与业务对象的属性联系在一起
        protected override void AddBusinessRules()
        {
            //AddRule的第一个参数是委托变量，也就是说是方法的变量
            ValidationRules.AddRule(CommonRules.StringRequired, "QuestionnaireName");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("QuestionnaireName", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "QAim");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("QAim", 100));
            ValidationRules.AddRule(CommonRules.StringRequired, "QNotice");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("QNotice", 150));
            ValidationRules.AddRule(CommonRules.StringRequired, "QSource");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("QSource", 40));
            ValidationRules.AddRule(CommonRules.StringRequired, "IsJumpOver");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("IsJumpOver", 1));
            ValidationRules.AddRule(CommonRules.StringRequired, "QSumup");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("QSumup", 200));
            ValidationRules.AddRule(CommonRules.StringRequired, "IsUsed");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("IsUsed", 1));
            ValidationRules.AddRule(CommonRules.StringRequired, "Explain");
            ValidationRules.AddRule(CommonRules.StringMaxLength, new Csla.Validation.CommonRules.MaxLengthRuleArgs("Explain", 100));
            //base.AddBusinessRules();
        }
        #endregion

        #region Factory Methods 工厂方法

        public V_TrQuestionnaire() { }

        public static V_TrQuestionnaire New()
        {
            return DataPortal.Create<V_TrQuestionnaire>();
        }
        public static V_TrQuestionnaire Get(Guid TrQuestionnaireID)
        {
            return DataPortal.Fetch<V_TrQuestionnaire>(new SingleLazyCriteria<V_TrQuestionnaire, Guid>(TrQuestionnaireID, false));
        }
        public static void Delete(Guid TrQuestionnaireID)
        {
            DataPortal.Delete(TrQuestionnaireID);
        }

        //public override TrQuestionnaire Save()
        //{
        //return base.Save();
        //}
        #endregion

        #region Data Access 数据访问
        //由于DataPortal_create中没有对数据库的访问，所有标记了Runlocal特性，使得该方法只需在本地运行即可
        //如果代码中有访问数据库的方法，那么就不要用这个特性，使数据门户可以根据情况将此方法的运行选择在应用服务器还是本地
        [RunLocal()]
        protected override void DataPortal_Create()
        {
            //在此调用CheckRules对所有的属性进行验证规则的检查，这样检查只运行一次。
            ValidationRules.CheckRules();
        }


        //可以看到此方法没有标记任何特性
        //此方法要访问数据库所以不能标记本地，由于她没有任何数据库更新操作所以也无需事务性的保护
        //此方法调用结束后会隐含的调用MarkOld（）方法
        private void DataPortal_Fetch(Guid TrQuestionnaireID)
        {
            //通过连接字符串建立SQL连接对象，Using符号代表，范围释放的意思，SqlConnection对象会在此范围后被释放掉
            using (var ctx = ConnectionManager<SqlConnection>.GetManager(ConnectionStringNames))
            {
                IDb db = DbFactory.Instance.GetDb(ctx.Connection);
                IQuery q = db.Query();
                q.Constrain("TrQuestionnaireID").Equal(TrQuestionnaireID);
                var data = db.Select<V_TrQuestionnaire>(q)[0];
                LoadProperty(TrQuestionnaireIDProperty, data.TrQuestionnaireID);
                LoadProperty(QStyleIDProperty, data.QStyleID);
                LoadProperty(DeptIDProperty, data.DeptID);
                LoadProperty(QuestionnaireNameProperty, data.QuestionnaireName);
                LoadProperty(DeptNameProperty, data.DeptName);
                LoadProperty(QAimProperty, data.QAim);
                LoadProperty(SubjectSumProperty, data.SubjectSum);
                LoadProperty(PointSumProperty, data.PointSum);
                LoadProperty(QStartTimeProperty, data.QStartTime);
                LoadProperty(QEndTimeProperty, data.QEndTime);
                LoadProperty(QTimeLengthProperty, data.QTimeLength);
                LoadProperty(QNoticeProperty, data.QNotice);
                LoadProperty(QSourceProperty, data.QSource);
                LoadProperty(IsJumpOverProperty, data.IsJumpOver);
                LoadProperty(QSumupProperty, data.QSumup);
                LoadProperty(IsUsedProperty, data.IsUsed);
                LoadProperty(ExplainProperty, data.Explain);
                LoadProperty(AddUserProperty, data.AddUser);
                LoadProperty(AddTimeProperty, data.AddTime);
            }
        }

        [Transactional(TransactionalTypes.TransactionScope)]
        protected override void DataPortal_DeleteSelf()
        {
            //依然是调用下面的方法删除的，只是他此时可以获得自己的Id
            DataPortal_Delete(TrQuestionnaireIDProperty);
        }
        #endregion
    }
}

